import Vue from 'vue'

import 'normalize.css/normalize.css' // A modern alternative to CSS resets

import ElementUI from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'
import locale from 'element-ui/lib/locale/lang/en' // lang i18n

import '@/styles/index.scss' // global css

import App from './App'
import store from './store'
import router from './router'

import PageTools from '@/components/PageTools'
Vue.component('PageTools', PageTools)

import '@/icons' // icon
import '@/permission' // permission control

//  引入所有的自定义指令 得到i一个对象
import * as directives from '@/directives'
// 遍历所有的导出的指令对象，完成自定义指令的全局注册
Object.keys(directives).forEach(key=>{
  // console.log(directives[key], 'key')
  // 全局注册自定义指令
  Vue.directive(key, directives[key]) // directives[key] 对应指令的操作
})

// 过滤器
import * as filters from '@/filters'
// 注册全局过滤器
Object.keys(filters).forEach(key=>{
  Vue.filter(key,filters[key])
})

// 上传文件
import components from '@/components'
// 注册自定义组件
Vue.use(components) // Vue.use 执行的是install方法

// set ElementUI lang to EN
Vue.use(ElementUI, { locale })
// 如果想要中文版 element-ui，按如下方式声明
// Vue.use(ElementUI)

// 打印
import Print from 'vue-print-nb'
Vue.use(Print)

Vue.config.productionTip = false

new Vue({
  el: '#app',
  router,
  store,
  render: h => h(App)
})
